package com.sojson.project.dao;

import java.sql.SQLException;
import java.util.ArrayList;

import com.sojson.base.BaseDao;
import com.sojson.project.entity.po.Auth;

/**
 * 权限表Dao
 * 
 * @author liu
 * @date 2021-03-16
 */
public interface AuthDao extends BaseDao<Auth> {

    /**
     * 通过id删除(物理删除)
     * 
     * @param id
     * @return
     * @throws SQLException
     */
    int deleteById(Integer id);

    /**
     * 通过id列表删除(物理删除)
     * 
     * @param ids
     * @return
     * @throws SQLException
     */
    int deleteByIdList(ArrayList<Integer> ids);

    /**
     * 通过id更新(全部更新)
     * 
     * @param auth
     * @return
     * @throws SQLException
     */
    int updateById(Auth auth);

    /**
     * 通过id列表更新(全部更新)(更新内容相同)
     * 
     * @param auth
     * @return
     * @throws SQLException
     */
    int updateStaticByIdList(Auth auth);

    /**
     * 通过id列表更新(全部更新)(更新内容不相同)
     * 
     * @param auths
     * @return
     * @throws SQLException
     */
    int updateChangeByIdList(ArrayList<Auth> auths);

    /**
     * 通过id更新(局部更新)
     * 
     * @param auth
     * @return
     * @throws SQLException
     */
    int updatePartialById(Auth auth);

    /**
     * 通过id列表更新(局部更新)(更新内容相同)
     * 
     * @param auth
     * @return
     * @throws SQLException
     */
    int updateStaticPartialByIdList(Auth auth);

    /**
     * 通过id列表更新(局部更新)(更新内容不相同)
     * 
     * @param auths
     * @return
     * @throws SQLException
     */
    int updateChangePartialByIdList(ArrayList<Auth> auths);

    /**
     * 通过id查询
     * 
     * @param id
     * @return
     * @throws SQLException
     */
    Auth findById(Integer id);

    /**
     * 通过id列表查询
     * 
     * @param ids
     * @return
     * @throws SQLException
     */
    ArrayList<Auth> findByIdList(ArrayList<Integer> ids);

    /**
     * 通过对象查询id列表
     * 
     * @param auth
     * @return
     * @throws SQLException
     */
    ArrayList<Integer> findIdByDto(Auth auth);

    /**
     * 清空数据(物理清空)
     * 
     * @throws SQLException
     */
    void clear();

}